<!--
  ~ Licensed to the Apache Software Foundation (ASF) under one or more
  ~ contributor license agreements.  See the NOTICE file distributed with
  ~ this work for additional information regarding copyright ownership.
  ~ The ASF licenses this file to You under the Apache License, Version 2.0
  ~ (the "License"); you may not use this file except in compliance with
  ~ the License.  You may obtain a copy of the License at
  ~
  ~    http://www.apache.org/licenses/LICENSE-2.0
  ~
  ~ Unless required by applicable law or agreed to in writing, software
  ~ distributed under the License is distributed on an "AS IS" BASIS,
  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  ~ See the License for the specific language governing permissions and
  ~ limitations under the License.
  ~
  -->

<div class="pipeline-validation-hint">
    <sp-error-hint
        *ngIf="!readonly"
        [displayMessages]="!isPipelineAssemblyEmpty()"
        [errorMessages]="pipelineValidationService.errorMessages"
        [validationString]="'Pipeline'"
    >
    </sp-error-hint>
</div>

<sp-pipeline-assembly-drawing-area-pan-zoom
    #zoomComponent
    [pipelineCanvas]="pipelineCanvas"
    [jsplumbBridge]="jsplumbBridge"
>
</sp-pipeline-assembly-drawing-area-pan-zoom>

<div class="pipeline-canvas-outer" #outerCanvas>
    <sp-pipeline
        class="canvas jtk-surface"
        id="assembly"
        #pipelineComponent
        [pipelineValid]="pipelineValid"
        [rawPipelineModel]="rawPipelineModel"
        [allElements]="allElements"
        [readonly]="readonly"
        [metricsInfo]="metricsInfo"
        [previewModeActive]="previewModeActive"
        [pipelinePreview]="pipelinePreview"
        (triggerPipelineCacheUpdateEmitter)="
            triggerPipelineCacheUpdateEmitter.emit()
        "
        style="position: absolute"
    >
    </sp-pipeline>
</div>
